Amendments to the Claims 

1-10 (canceled). 

1 1 (currently amended). In a multi-tasking computer system comprising 
a plurality of resources to be shared by a plurality of tasks, a circuit for allocating each 
resource to the tasks so that after any one of the tasks has finished accessing any one of the 
resources in processing a data unit, th e task said one of the tasks does not get access to the 
same resource until after every other one of the tasks has finished accessing the resource; 

wherein accessing any one of said resources by any one of said tasks comprises: 

(1) the task attempting to access the resource, wherein attempting to access the 
resource comprises generating a signal indicating that the task is attempting to access the 
resource; 

(2) in response to the operation (1), the circuit allowing the task to access the 
resource if the resource is available to the task, the circuit not allowing the task to access the 
resource imtil the resource becomes available to the task: 

(3) the task accessing the resource when the circuit allows the task to access the 
resource: 

wherein for any task Tl of said tasks and any resource Rl of said resources, if the 
task Tl attempts to access the resource Rl after the task Tl has already finished accessing 

the resource Rl, and at least one other task T2 has not attempted to access the resource Rl 
after the task Tl has finished accessing the resource Rl, then the circuit does not allow the 
task Tl to access the resource Rl until the task T2 attempts to access the resource Rl and 
accesses the resource Rl . 

12 (original). The circuit of Claim 1 1 wherein for at least one resource, each task 
starts accessing the resource by locking the resource to make it unavailable to any other task, 
and the task finishes accessing the resource by unlocking the resource. 

13 (currently amended). A method for sharing a plurality of resources by a 
plurality of computer tasks, the method comprising each of said tasks accessing each of said 
resources; 
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wherein accessing any one of said resources by any one of said tasks comprises : 
allowing a task Tl, which ia one of the tasks, to acccoo all of the rcaourccs, and 
disallowing any other task from accessing any one of the resources; and 

for each resource, after the task Tl has finished accessing the resource, allowing 
another task to access the resource, and disallowing the task Tl from acoossing th e resourc i 
until e very other task sharing the r e source has finished accessing th e r e source. 

(U the task generating a signal indicating that the task is attempting to access the 
resource: 

(2) in response to the operation (1). allowing the task to access the resource if the 
resource is available to the task, but not allowing the task to access the resource until the 
resource becomes available to the task; 

(3) the task accessing the resource when allowed to access the resource; 

wherein for any task Tl of said tasks and any resource Rl of said resources, if the 
task Tl attempts to access the resource Rl after the task Tl has already finished accessing 
the resource Rl, and at least one other task T2 has not attempted to access the resource Rl 
after the task Tl has finished accessing the resource Rl, then the circuit does not allow the 
task Tl to access the resource Rl until the task T2 attempts to access the resource Rl and 
accesses the resource Rl . 

14-29 (canceled). 

30 (previously presented). The circuit of Claim 1 1 wherein each data unit is 
processed by a single one of the tasks which accesses at least two of said resources to 
process at least one of the data units. 

3 1 (previously presented). The circuh of Claim 30 wherein said at least two 
resources are storage areas each of which is to store data imit processing information of 
multiple data units. 

32 (currently amended). The circuit of Claim 3 1 wherein one of the storage 
areas is a request FIFO for storing requests to process data units, and another one of the 
storage areas is a command FIFO for storing commands for processing of the data units; 
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wherein for each data unit, one of the tasks reads a request from the request FIFO 
and, if one or more commands are to be written to the command FIFO for the data unit, smd 
one of the tasks writes the one or more commands to the command FIFO. 

33 (previously presented). The circuit of Claim 32 wherein each request contains 

an address of a corresponding data unit. 

34 (previously presented). The circuit of Claim 3 1 wherein at least some of the 
data units are received over a network, wherein one of the storage areas is a request FIFO 
for storing requests to process the data units, and another of the storage areas is a status 
FIFO for storing status information on reception of the data units over the network; 

wherein for each data unit, one of the tasks reads a request from the request FIFO 
and reads the status information from the status FIFO. 

35 (previously presented). The method of Claim 13 wherein for at least one 
resource, each task starts accessing the resource by locking the resource to make it 
unavailable to any other task, and the task finishes accessing the resource by unlocking the 
resource. 

36 (previously presented). The method of Claim 1 3 wherein each data unit is 
processed by a single one of the tasks which accesses at least two of said resources to 
process at least one of the data units. 

37 (previously presented). The method of Claim 36 wherein said at least two 
resources are storage areas each of which is to store data unit processing information of 
multiple data units. 

38 (previously presented). The method of Claim 37 wherein one of the storage 
areas is a request FIFO for storing requests to process data units, and another one of the 
storage areas is a command FIFO for storing commands for processing of the data units; 

wherein for each data unit, one of the tasks reads a request from the request FIFO 
and, if one or more commands are to be written to the command FIFO for the data unit, said 
one of the tasks writes the one or more commands to the command FIFO. 
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39 (previously presented). The method of Claim 38 wherein each request contains 
an address of a corresponding data unit. 

40 (previously presented). The method of Claim 37 wherein at least some of the 
data units are received over a network, wherein one of the storage areas is a request FIFO 
for storing requests to process the data units, and another of the storage areas is a status 
FIFO for storing status information on reception of the data units over the network; 

wherein for each data unit, one of the tasks reads a request from the request FIFO 
and reads the status information from the status FIFO. 

41 (new). The circuit of Claim 30 wherein in each said storage area, the data 
processing information is associated with an order of data units, the order being the same for 
each said storage area. 

42 (new). The method of Claim 37 wherein in each said storage area, the data 
processing information is stored in association with an order of data units, the order being 
the same for each said storage area. 
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